{% extends 'layout/basic.html' %}

{% load static %}

{% block title %}{% endblock %}

{% block css %}
    <link rel="stylesheet" href="{% static 'css/account.css' %}">
{% endblock %}


{% block content %}
    <div class="container">
        <div class="account">
            <div class="title">用户注册</div>
            <form id="regForm" method="post" novalidate>
                {% csrf_token %}
                {% for field in form %}
                    {% if field.name == 'code' %}
                        <div class="form-group">
                            <label for="{{ field.id_for_label }}">{{ field.label }}</label>
                            <div class="clearfix">
                                <div class="col-md-6" style="padding-left: 0px;">
                                    {{ field }}
                                    <span class="error-msg"></span>
                                </div>
                                <div class="col-md-6">
                                    <input id="btnSms" type="button" class="btn btn-primary" value="获取验证码">
                                </div>
                            </div>
                        </div>
                    {% else %}
                        <div class="form-group">
                            <label for="{{ field.id_for_label }}">{{ field.label }}</label>
                            {{ field }}
                            <span class="error-msg"></span>
                        </div>
                    {% endif %}
                {% endfor %}
                <div class="row">
                    <div class="col-xs-3">
                        <button id="btnSubmit" type="button" class="btn btn-primary">注  册</button>
                    </div>
                </div>
            </form>
        </div>
    </div>
{% endblock %}

{% block js %}
    <script>
    // 页面加载完成自动执行
    $(function () {
        bindClickBtnSms();
        bindClickSubmit();
    });

    // 注册
    function bindClickSubmit() {
        $('#btnSubmit').click(function () {
            $('.error-msg').empty();

            // 获取数据 所以字段的数据和csrf token
            var data = $('#regForm').serialize();
            // 发送请求
            $.ajax({
                url: '{% url "web:register" %}',
                type: 'POST',
                data: data,
                dataType: 'JSON',
                success: function (res) {
                    // 跳转到登录页面
                    if(res.status){
                        location.href = res.data;
                    }else{
                        $.each(res.error, function (key, value) {
                            $('#id_'+key).next().text(value[0]);
                        });
                    }
                }
            })
        });
    }

    // 绑定事件到标签元素
    function bindClickBtnSms() {
        $('#btnSms').click(function () {
            // 获取手机号
            var mobilePhone = $('#id_phone').val();

            // 发送请求
            $.ajax({
                url: '{% url "web:send_sms" %}',
                type: 'GET',
                data: {phone: mobilePhone, tpl: 'register'},  // 发送到后端的数据
                dataType:'JSON', //将后端返回的数据反序列成字典
                success: function (res) {

                    // 清空页面上的错误信息
                    $('.error-msg').empty();

                    // ajax请求成功后，自动执行，res为后端返回的数据
                    console.log(res);
                    if(res.status){
                        // 成功
                        sendSmsRemind();
                    }else{
                        // 失败，在页面显示错误信息
                        $.each(res.error, function (key, value) {
                            $('#id_'+key).next().text(value[0]);
                        });
                    }
                },

            })
        });
    }
    
    // 发送短信后，倒计时
    function sendSmsRemind() {
        var $smsBtn = $('#btnSms');
        // 禁用
        $smsBtn.prop('disabled', true);

        var time = 60;
        var remaind = setInterval(function () {
            $smsBtn.val(time + '秒重新发送');
            time = time - 1;

            if (time < 1){
                // 清除定时器
                clearInterval(remaind);
                // 启用
                $smsBtn.val('点击获取验证码').prop('disabled', false);
            }
        }, 1000)
    }
    </script>
{% endblock %}
